Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

text: Skip setting HTML text when it hasn't changed #19012

Merged
merged 5 commits into from
Jan 5, 2025

Conversation

kjarosh
Copy link
Member

@kjarosh kjarosh commented Dec 18, 2024

Flash Player checks whether we're setting htmlText to a different value before doing it. It not only prevents text relayout, but also has observable effects, because not every set of spans can be represented as HTML.

This is especially affecting input text fields with bound variables, as text propagation will set the value back, and we can produce spans not representable as HTML during input.

Additionally, this PR fixes <p>'s align case sensitivity.

@kjarosh kjarosh added text Issues relating to text rendering/input A-core Area: Core player, where no other category fits T-fix Type: Bug fix (in something that's supposed to work already) labels Dec 18, 2024
@adrian17
Copy link
Collaborator

This is especially affecting input text fields with bound variables, as text propagation will set the value back,

What do you mean? Aren't they supposed to be always synced anyway?

@kjarosh
Copy link
Member Author

kjarosh commented Dec 18, 2024

This is especially affecting input text fields with bound variables, as text propagation will set the value back,

What do you mean? Aren't they supposed to be always synced anyway?

They are, but due to the fact that HTML cannot represent all possible contents, it gets tricky. I'm talking specifically about the following scenario:

  1. The text field has value 1\n (represented as <p align="center">1</p>)
  2. The user deletes \n, leaving 1 (represented as <p align="center">1</p>)
  3. Now the binding kicks in, it sets the value of the variable
  4. The binding synchronizes the value back, setting the text field to <p align="center">1</p>
  5. The text field now has value 1\n, which is wrong (it should be 1)

Now the fact that the binding synchronizes the value back doesn't matter, because when you do the same without binding, it behaves the same way (i.e. the value is 1, not 1\n). This case is covered by the test.

Unfortunately, the tests now started to fail, which means I have found yet another bug related to when the relayout takes place (yay! I guess?).

@adrian17
Copy link
Collaborator

To be sure, is the full roundtrip ("binding synchronizes the value back") needed, or is it more like "it's simpler this way and doesn't impact any behavior by itself"?

@kjarosh
Copy link
Member Author

kjarosh commented Dec 18, 2024

To be sure, is the full roundtrip ("binding synchronizes the value back") needed, or is it more like "it's simpler this way and doesn't impact any behavior by itself"?

So first of all, I did it this way not because it's simpler, but because it's correct. The binding has nothing to do with this behavior, it just happens to occur with a binding.

I don't think the roundtrip is needed (but I'm not sure), I think after this PR it will just be a useless string comparison + property lookup. I guess that could be optimized, but I'm not sure if that's worth it.

@adrian17
Copy link
Collaborator

So first of all, I did it this way not because it's simpler, but because it's correct.

I wasn't questioning the PR at all, sorry if it seemed that way. Was just making sure about the roundtrip.

Copy link
Collaborator

@adrian17 adrian17 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ah, sorry, reversing the approve, since you mentioned that new bug 😅

@kjarosh
Copy link
Member Author

kjarosh commented Dec 18, 2024

I wasn't questioning the PR at all, sorry if it seemed that way. Was just making sure about the roundtrip.

No worries! I wasn't thinking that, just wanted to emphasize (for everyone) that the binding thing is not that important here 😄

@kjarosh
Copy link
Member Author

kjarosh commented Dec 19, 2024

@adrian17 Should be good now, added some more test cases here too

This fixes issues with setting align to a value that isn't lowercase.
Added cases related to case sensitivity of p's align attribute.
This behavior not only prevents text relayout,
but it also has observable effects, because not
every set of spans is representable as HTML.
This behavior not only prevents text relayout,
but it also has observable effects, because text
format is not being reset to the default format.
This test verifies the behavior of htmlText when
setting to the same value.
@kjarosh kjarosh enabled auto-merge (rebase) January 5, 2025 08:44
@kjarosh kjarosh merged commit d5f06ac into ruffle-rs:master Jan 5, 2025
22 checks passed
@kjarosh kjarosh deleted the text-html-same branch January 5, 2025 09:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-core Area: Core player, where no other category fits T-fix Type: Bug fix (in something that's supposed to work already) text Issues relating to text rendering/input
Projects
None yet
Development

Successfully merging this pull request may close these issues.

(NSFW) Animation #6 - Shade - Can only type three numerical numbers instead of four
2 participants